Skip to content

Conversation

@ibash
Copy link

@ibash ibash commented Feb 8, 2018

@MatthieuLemoine I made this change so that we can opt-in to throwing errors. We catch these and send them to bugsnag, so it should help with catching any edge cases in the gcm code.

ibash added 3 commits January 31, 2018 15:57
This commit:
1. Prevents sending messages to destroyed webContents (which result in a crash)
2. Allows registering multiple webContents for push notifications

We need this because we are listening for notifcations in a specific
webContents. If it crashes we create a new one and call setup again,
without this change the next push notification that came in would cause
a crash.
That seems to be crashing the app ref: electron/electron#11797
@MatthieuLemoine
Copy link
Owner

Can't we use NOTIFICATION_SERVICE_ERROR for this ?

@ibash
Copy link
Author

ibash commented Feb 8, 2018

I did that at first, but realized I actually wanted the errors in the main process, since that's where I have bugsnag set to catch them. I'm happy for this not to be merged into the main project, as it's kind of an odd use case, and I'm mostly doing it to help flush out any bugs with the changes to push-receiver.

FWIW we're rolling the push-receiver changes, so it'll start getting some production testing :)

// Retrieve saved senderId
const savedSenderId = config.get('senderId');
if (started) {
webContents.send(NOTIFICATION_SERVICE_STARTED, (credentials.fcm || {}).token);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Accessing 'fcm' from 'credentials' object will results in error when 'credentials' object is null.

can we re-write like ((credentials && credentials.fcm) || {}).token)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants